﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Support.DTO;
using System.Data;
using System.Data.SqlClient;

namespace DataAccess
{
    public class LocalidadDAL : BaseSQLDAL
    {
        public List<LocalidadDTO> GetLocalidadesByProvId(int provinciaId)
        {
            List<LocalidadDTO> localidades = new List<LocalidadDTO>();

            try
            {

                CreateCommand("Localidad_ObtenerPorProvinciaId", true);
                AddCmdParameter("@ProvinciaId", provinciaId, ParameterDirection.Input);

                ExecuteReader();
                while (Read())
                {
                    localidades.Add(FillDTO(GetDataReader()));
                }
                return localidades;
            }
            catch (Exception ex)
            {
                throw ex;
            }
            finally
            {
                DisposeCommand();
                DisposeDataReader();
                CloseConnection();
            }
        }


        public LocalidadDTO GetLocalidadById(int localidadId)
        {
            try
            {
                LocalidadDTO localidad = new LocalidadDTO();
                CreateCommand("Localidad_ObtenerPorId", true);
                AddCmdParameter("@LocalidadId", localidadId, ParameterDirection.Input);

                ExecuteReader();
                while (Read())
                {
                    localidad = FillDTO(GetDataReader());
                }
                return localidad;
            }
            catch (Exception ex)
            {
                throw ex;
            }
            finally
            {
                DisposeCommand();
                DisposeDataReader();
                CloseConnection();
            }
        }


        private LocalidadDTO FillDTO(SqlDataReader reader)
        {
            return new LocalidadDTO()
            {
                Id = reader.GetInt32(reader.GetOrdinal("IdLocalidad")),
                Name = reader.GetString(reader.GetOrdinal("Nombre")),
                ProvinciaId = reader.GetInt32(reader.GetOrdinal("IdProvincia")),
            };
        }
    }
}
